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(54) Apparatus and method for generating code in a communication system 



(57) A QCTC (Quasi-Complementary Turbo Code) 
generating apparatus having: a turbo encoder for gen- 
erating an information symbol sequence and a plurality 
of parity symbol sequences by encoding the information 
symbol sequence: a channel interleaver for individually 
interleaving the symbol sequences, generating new par- 
ity symbol sequences by multiplexing the symbols of 



parity symbol sequences with the same priority levels, 
and serially concatenating the information symbol se- 
quence and the new parity symbol sequences: and a 
QCTC generator for generating a sub-code with a given 
code rate by recursively selecting a predetermined 
number of symbols from the concatenated symbol se- 
quence at a given starting position. 
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Description 
PRIORITY 

[0001] This application claims priority to an application entitled "Apparatus and Method for Generating Codes in 
Communication System" filed in the Korean Industrial Property Office on February 13. 2001 and assigned Serial No. 
2001-8275, and to an application entitled "Apparatus and Method for Generating Codes in Communication System" 
filed in the Korean Industrial Property Office on February 14. 2001 and assigned Serial No. 2001-7357, trie contents 
of both of which are hereby incorporated by reference. 

BACKGROUND OF THE INVENTION 

1. Field of the Invention 



[0002] The present invention relates generally to code generation in a data communications system, and in particular, 
to an apparatus and method for generating complementary turbo codes, considering the characteristics of turbo codes 
in a packet communications system or a general communications system that employs a retransmission scheme. 

2. Description of the Related Art 

[0003] In general, a system using a retransmission scheme (e.g., HARQ: Hybrid Automatic Repeat Request) per- 
forms soft combining to improve transmission throughput. The soft combining techniques are divided into packet di- 
versity combining and packet code combining. These two combining schemes are usually called soft packet combining. 
Although the packet diversity combining scheme is sub-optimal in performance relative to the packet code combining 
scheme, it is favorable due to easy implementation when performance loss is low. 

[0004] A packet transmission system uses the packet code combining scheme to improve transmission throughput. 
A transmitter transmits a code with a different code rate at each packet transmission. If an error is detected from the 
received packet, a receiver requests a retransmission and performs soft combining between the original packet and a 
retransmitted packet. The retransmitted packet may have a different code from the previous packet. The packet code 
combining scheme is a process of combining received N packets with a code rate R to a code with an effective code 
rate of R/N prior to decoding, to thereby obtain a coding gain. 

[0005] With regard to the packet diversity combining scheme, on the other hand, the transmitter transmits the same 
code with a code rate R at each packet transmission. If an error is detected from the received packet, the receiver 
requests a retransmission and performs soft combining between the original packet and the retransmitted packet. The 
retransmitted packet has an identical code to that in the previous packet. In this sense, the packet diversity combining 
scheme can be considered the received symbol energy averaging on a random channel. The packet diversity combining 
scheme reduces noise power by averaging the soft outputs of the received input symbols and achieves such a diversity 
gain as offered by a multi-path channel because the same code is repeatedly transmitted on a fading channel. However, 
the packet diversity combining scheme does not provide such an additional coding gain as obtained according to a 
code structure in the packet code combining scheme. 

[0006] In the meanwhile, a turbo encoder generating the turbo code will be described hereinbelow. In the case of a 
turbo encoder with R=1/5, the turbo encoder generates information symbols X. first parity symbols Y 0 . Y 0 ' and second 
parity symbols Y v Y/ by encoding input information symbols. The turbo encoder is comprised of two constituent en- 
coders and one interleaver. The first parity symbols Y 0 and Y 0 ' are output from a first constituent encoder by encoding 
the input information symbols and the second parity symbols Y 1 and Y t ' from a second constituent encoder by encoding 
the information symbols interleaved through the interleaver. In detail, the Y 0 is a row of first parity symbols generated 
from a first constituent encoder, and the Yq! is a row of second parity symbols generated from the first constituent 
encoder. 

[0007] Due to implementation simplicity, most packet communication systems have used the packet diversity com- 
bining scheme, which is under study for application to the synchronous IS-2000 system and the asynchronous UMTS 
system. The reason is that the existing packet communication systems have used convolutional codes and even packet 
code combining does not offer a great gain when convolutional codes with a low data rate are used. If a system with 
R=1/3 supports retransmission, there is not a wide difference in performance between the packet code combining 
scheme and the packet diversity combining scheme. Thus, the packet diversity combining scheme is selected consid- 
ering implementation complexity. However, use of turbo codes as forward error correction codes (FEC) requires a 
different packet combining mechanism because the turbo codes are designed as error correction codes to have per- 
formance characteristics very close to the "Shannon Channel Capacity Limit" and their performance varies obviously 
with the coding rates unlike convolutional codes. Therefore, it can be concluded that packet code combining is desirable 
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for a packet communication system using turbo codes in a retransmission scheme to achieve the goal of optimum 
performance. 

SUMMARY OF THE INVENTION 

5 

[0008] It is. therefore, an object of the present invention to provide an apparatus and method for generating sub- 
codes that enable optimum code combining in a retransmission system using turbo codes. 

[0009] It is another object of the present invention to provide an apparatus and method for generating complementary 
codes using turbo codes in a communication system. 

w [0010] It is a further object of the present invention to provide an apparatus and method for generating sub-codes 
to be generated after channel interleaving in a retransmission system using channel interleaving. 
[0011] The foregoing and other objects of the present invention are achieved by providing a QCTC (Quasi-Comple- 
mentary Turbo Code) generating apparatus. In the QCTC generating apparatus, a turbo encoder has a plurality of 
constituent encoders and at least one interleaver and generates an information symbol sequence and a plurality of 

15 parity symbol sequences according to a given code rate by encoding the information symbol sequence. The constituent 
encoders generate the plurality of parity symbol sequences, each of the constituent encoders generates at least one 
parity symbol sequence, and the at least one parity symbol sequence from one constituent encoder corresponds to 
the at least one parity symbol sequence from another constituent encoder. A channel interleaver individually interleaves 
the information symbol sequence and the parity symbol sequences, alternately arranges the symbols of the corre- 

20 sponding parity symbol sequences, and serially concatenates the interleaved information symbol sequence and the 
arranged parity symbol sequences. A QCTC generator generates a sub-code of a QCTC by repeating the serially 
concatenated symbol sequence and selecting a predetermined number of symbols from the repeated symbol sequence 
according to code rate and selection information. 

25 BRIEF DESCRIPTION OF THE DRAWINGS 

[0012] The above and other objects, features and advantages of the present invention will become more apparent 
from the following detailed description when taken in conjunction with the accompanying drawings in which: 

30 FIG. 1 is a schematic block diagram of a QCTC (Quasi-Complementary Turbo Code) generating apparatus ac- 

cording to the present invention; 

FIG. 2 is a block diagram of an embodiment of the QCTC generating apparatus according to the present invention; 
and 

FIG. 3 is a block diagram of another embodiment of the QCTC generating apparatus according to the present 
35 invention. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

[0013] Preferred embodiments of the present invention will be described hereinbelow with reference to the accom- 
<to panying drawings. In the following description, well-known functions or constructions are not described in detail since 
they would obscure the invention in unnecessary detail. 

[0014] The present invention provides a QCTC generating method for a system using channel interleaving and a 
method of generating QCTCs in a predetermined way irrespective of a variable code length in a system requiring 
QCTCs with a variety of code rates. A QCTC is defined as a complementary code generated using a turbo code. The 

45 QCTC is not a perfect complementary code as noted from the term "quasi" because a sub-code includes repeated 
symbols and has a different characteristic such as error correcting capability from another sub-code. 
[0015] FIG. 1 is a schematic block diagram of a QCTC generating apparatus according to the present invention. The 
QCTC generating apparatus shown in FIG. 1 is characterized by carrying out symbol sequence repetition and punc- 
turing after channel interleaving when generating sub-codes. 

so [0016] Referring to FIG. 1. an encoder 101 generates code symbols by encoding an input encoder packet. A con- 
volutional encoder or a turbo encoder can be used as the encoder 101. The encoder 101 has a code rate of. for 
example. 1/5. For the input of 3.072 information bits, the encoder 101 outputs 15.360 code symbols. A channel inter- 
leaver 102 interleaves the code symbols according to a predetermined rule. If the encoder 101 is a turbo encoder, the 
interleaver 102 interleaves information symbols X. and parity symbols Y 0 . Y, . Y 0 \ and Y t ' separately. A QCTC generator 

55 103 generates sub-codes by puncturing and repeating the interleaved symbols. The channel interleaver 102 and the 
QCTC generator 103 perform, the QCTC generation process. 

[0017] If the number of interleaved code symbols is 15.360 and the data rate (or code rate) of sub-codes is given as 
307.2kbps. the QCTC generator 103 generates the first sub-code having 21.504 symbols by taking the 15.360 inter- 
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leaved code symbols and repeating part of the first half of the interleaved code symbols. If the data rate is 614.4kbps. 
the QCTC generator 103 generates the first sub-code by taking the first 10.752 code symbols from the first half of the 
interleaved code symbols. And if the data rate is 1228.8kbps or 2457.6kbps. the QCTC generator 103 generates the 
first sub-code by taking the first 5.376 code symbols from the interleaved code symbols. 

5 [0018] To generate a QCTC (or sub-codes), the channel interleaver 102 should take particular characteristics be- 
cause the five symbols X, Y 0 . Y 1 . Y 0 \ and Y t " are distributed through channel interleaving and the distributed code 
symbols are not suitable for the input of the QCTC generator 103 and because it is not easy to generate sub-codes 
satisfying the characteristics of a QCTC with the mixed symbols of X. Y 0 , Y t . Y 0 \ and Y t \ In this context, the present 
invention provides a method of generating a QCTC in a predetermined way irrespective of the code rate of each sub- 

w code. 

[0019] FIG. 2 is a block diagram of the QCTC generating apparatus according to an embodiment of the present 
- invention. 

[0020] Referring to FIG. 2. an encoder 201 generates code symbols by encoding input information symbols (i.e. input 
encoder packet). The encoder 201 uses a mother code with R=1/5 or with any other code rate. A mother code is 

'5 determined by the system used. A turbo code with R=1/5 is used herein as a mother code by way of example. Then, 
the encoder 201 generates information symbols X. first parity symbols Y 0 and Y 0 ' and second parity symbols Yj and 
Y," by encoding input information symbols. The first parity symbols Y 0 and Y 0 ' are output from a first constituent encoder 
and the second parity symbols Y, and Y/ from a second constituent encoder. The first and second constituent encoders 
(not shown) are contained in encoder 201 . The primary parity symbols Y 0 and Y, from the first and second constituent 

20 encoders have a higher transmission priority than the secondary parity symbols Y 0 ' and Y,'. 

[0021] A demultiplexer (DEMUX) 202 groups the code symbols received from the encoder 201 into information sym- 
bols X 203. parity symbols Y 0 213. parity symbols Y 1 223, parity symbols Y 0 * 233. and parity symbols Y,' 243 and 
outputs the five symbol groups to corresponding respective interleaves 204. 214. 224. 234 and 244. 
[0022] Interleaves 204, 214 . 224,234 and 244 randomly permute the sequences of the input code symbols by in- 

25 terieaving. Various interleaving methods are available as long as the following condition is satisfied. 

[0023] (Condition) Interleaved code symbols are partially punctured in such a way that the puncturing pattern of code 
symbols before interleaving has a uniform puncturing distance. 

[0024] The reason for satisfying the above condition is that when code symbol groups X. Y 0 . Y lf Y 0 \ and Y t * are 
punctured in the same number of code symbol positions, the distance between punctured code symbol positions in 
20 the code symbols before interleaving must be equal to achieve optimum turbo code performance. In other words, when 
puncturing is applied to turbo codes, uniformity is a significant factor that determines the performance of the turbo 
codes. In accordance with the present invention, sub-block interleaving applies independently to the code symbols X. 
Y 0 . Y 0 \ Y v and Y^. Uniform puncturing in each interleaver output maintains, an equal distance between punctured 
code symbols in encoder output. Therefore, it can be concluded that channel interleaving must be chosen so that 
35 puncturing in interleaved code symbols can maintain a uniform puncturing distribution in channel encoder output. 

[0025] Such channel interleaving methods include bit reversal order (BRO) interleaving and partial bit reversal order 
(PBRO) interleaving. The BRO interleaving is practicable only if the number of input information symbols to an encoder 
and the number of each code symbol set X, Y 0 , Y 0 \ Y v and Y,* are powers of 2. that is, 2 m . wherein m is a parameter 
to make a block size of sub block interleaver such as block size N=2 m *J. 
40 [0026] The PBRO interleaving was designed to satisfy the afore-stated condition even if the number of information 
symbols and the number of each encoder output symbol set X. Y 0 . Y 0 \ Y 1# and Y t ' are not powers of 2 in order to 
overcome the limitation of the BRO interleaving. A detailed description of this sub-block channel interleaving will be 
avoided here and it is to be noted that any channel interleaving method can be implemented in the present invention 
as long as it satisfies the above condition. 
45 [0027] The interleaved code symbols X 206 (shown as a block for convenience) output from the first interieaver 204 
are applied directly to the input of a symbol concatenator 207. The interleaved code symbols Y 0 and Y, from the second 
and third interleaves 214 and 224 are input to a first multiplexer (MUX) 205 and the interleaved code symbols Y 0 * and 
Y\ from the fourth and fifth interleaves 234 and 244. to a second MUX 215. That is. the first MUX 205 receives the 
primary parity symbols and the second MUX 21 5 receives the secondary parity symbols. 
»jc^.(0028] *f~The first MUX 205 multiplexes the interleaved parity symbols Y 0 and Y^ 216 and feeds the output to the symbol 
concatenator 207. The second MUX 215 multiplexes the interleaved parity symbols Y 0 ' and Y,' 226 and feeds its output 
ymboi.concatenator 207. That is, the MUXes 205 and 215 multiplex the parity symbol sequences by priority 
level With the aid of the MUXes 205 and 215, the interleaver outputs are rearranged and then divided into three sub- 
206^216 and 226. 

I^^^^f above-described process, which is essential to generation of QCTCs according to the present invention. 
*^^^£??? fl * ed ,n ™ ore detai '- As shown in FIG. 2. information symbols X form an independent sub-group without 
P*M£iq through multiplexing after sub-block interleaving. Let the sub-block interleaved symbols be Sb X. which can 
*~ **"M*s#*d as 
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Sbg-Xtf). Sb f X(2). Sb,- X(3). So, X(A)... (1) 

where Sb, X(1 ) indicates the first code symbol output from the first interleaver 204. So, X is referred to as sequence A. 
[0030] Then, the interleaved code symbols Y 0 and Y n output from the second and third interleaves 214 and 224 are 
grouped into one sub-group. If the code symbols Y 0 are Sb, Y 0 . Sb L Y 0 can be expressed as 

Sb s Y 0 (V. Sb L Y Q (2). Sb L Y Q (3). Sb L Y Q (4)... (2) 

where Sb, Y 0 (1) indicates the first code symbol output from the second interleaver 214. If the code symbols Y 1 are 
Sb, Y v Sb, Y t can be expressed as 

Sb L Y^(1). Sb L YJ2). Sb L Y^(3). Sb L Y^(4)... (3) 

where Sb, Y t (1) and Sb, Y 1 (2) indicate the first and second code symbols respectively, output from the third interleaver 
224. After"muitiplexing the code symbols Yq and Y 1t 

Sb L Y Q 0). Sb L Y,(i). Sb L Y 0 (2). Sb f _Y,(2) t Sb f Y 0 (3). Sb, Y^;... (4) 
These multiplexed symbols are referred to as sequence B. 

(0031] The reason for multiplexing the interleaved code symbols Sb, Y 0 and Sb i _Y 1 is that when M successive sym- 
bols are punctured in the sequence B irrespective of the first half or second half of the sequence B, the number of 
punctured symbols in Sb, Y 0 i s equal to that of punctured symbols in Sbj Y, only if M is an even number. If M is an 
odd number, the difference between the numbers of punctured symbols in Sb L Y 0 and in Sb } Y 1 is only 1. The multi- 
plexing always satisfies the QCTC characteristic that the number of punctured parity symbols Y 0 is equal to that of 
punctured parity symbols Y v 

[0032] In the same manner, the interleaved code symbols Y 0 ' and Y,' output from the fourth and fifth interleaves 
234 and 244 are grouped into one sub-group. If the code symbols Y 0 ' and Y,* are Sb,_Y 0 * and Sbj Y^. respectively, 
Sb, Y 0 ' and Sb, Y t ' can be expressed as 

S*>iY Q V). Sb L Y Q '(2). Sb L Y Q '(3). Sb L Y Q '(4)... (5) 

and 

Sb g Y % V). Sb f Y A '(2). Sb f Y^(3), Sb L Y,'(4)... (6) 
Then, the output of the second MUX 21 5 is 

Sb L Y o m Sb g Y^ YU Sb,Y Q -(2). Sb f _Y^ '(2). Sb f Y Q '(3), So,-_ Y, '(3) - (?) 
These multiplexed symbols are referred to as sequence C. 

[0033] The reason for multiplexing the interleaved code symbols Sb L Y 0 * and Sb L Y n ' is that when M successive 
symbols are punctured in the sequence C irrespective of the first half or second half of the sequence C. the number 
of punctured symbols in Sbj Y 0 * is equal to that of punctured symbols in Sb, Y,* only if M is an even number. If M is an 
odd number, the difference between the numbers of punctured symbols in Sb L Y 0 ' and in Sb, Y t ' is only 1. The multi- 
plexing always satisfies the QCTC characteristic that the number of punctured parity symbols Y 0 * is equal to that of 
punctured parity symbols Y,\ 

[0034] The symbol concatenator 207 sequentially concatenates the sequences A. B and C of the first, second, and 
third sub-groups and generates a symbol sequence [A:B:C]. 
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(A :B : C] = (Sb,_Xn). Sb f .X(2). Sb L X(3)...J [Sb, Y 0 (\). Sb^Y^I). Sb s Y Q (2). 

Sb g Y t (2)....l(Sb L Y Q W. Sb L r t Yi;. Sb L Y 0 '(2). Sb f Y % (2)...].. (3) 

[0035] As seen from the above formula, information symbols are placed first, followed by alternating parity symbols 
Y 0 and Y, and then by alternating parity symbols Y 0 * and Y/ in the sequence [A:B:C]. This symbol arrangement assumes 
a very significant meaning in QCTC generation, which will be described below. 

[0036] Puncturing should be carried out to generate a sub-code with a code rate from the turbo code of (8). The 
puncturing is defined by a "QCTC". The QCTC should have the following characteristics. 

(1) Information symbols precede all other code symbols in transmission. Especially, as the code rate of sub-codes 
is close to 1. this characteristic becomes more important. 

(2) A puncturing pattern is formed so that the number of parity symbols output from each constituent encoder (a 
first constituent encoder and a second constituent encoder) is equal or their difference in number is minimum. 

(3) The number of punctured symbols in the parity symbols Y 0 and Y 0 * is determined such that the code rate of 
the first constituent encoder is always less than 1. That is, the performance of turbo codes is ensured when at 
least one parity symbol Y 0 or Y 0 ' exists. 

(4) The distance between punctured symbols in a QCTC resulting from puncturing is equal. 

(5) A turbo code produced by combining sub-codes of QCTCs assumes the characteristics of a quasi-complemen- 
tary code. 

[0037] A QCTC with a sub-code code rate, which is generated by puncturing or pruning as many symbols as nec- 
essary from the end of the symbol sequence [A:B:C), satisfies the above five characteristics. In other words, an intended 
sub-code of a QCTC is generated by repeating and puncturing as many symbols as needed in the symbol sequence 
[A:B:C] in a symbol sequence repeater 208 and a symbol puncturer 209. The symbol sequence repeater 208 repeats 
the symbol sequence received from the symbol concatenator in a predetermined way. The repetition method is deter- 
mined according to the code rate of the sub-code. The symbol puncturer 209 punctures or prunes as many symbols 
as a predetermined number, starting with the last symbol in the symbol sequence received from the symbol sequence 
repeater 208, to thereby create the sub-code of the QCTC. The number of punctured symbols depends on the code 
rate of the sub-code. Therefore, the code rate of the sub-code should be provided to the symbol sequence repeater 
208 and the symbol puncturer 209 in order to perform sequence repetition and symbol puncturing. Alternatively, a 
higher layer controller (not shown) can calculate the number of repeated symbols and the number of punctured symbols 
according to a mother code rate and a sub-code rate and feed the information to the symbol sequence repeater 208 
and the symbol puncturer 209. 

[0038] In other words, the symbol puncturer 209 selects a predetermined number of symbols counted from a given 
symbol position in the symbol sequence received from the symbol sequence repeater 208. thereby generating the sub- 
code of the QCTC. The given symbol position refers to the symbol next to the last symbol selected for the previous 
transmission. Therefore, the symbol puncturer 209 can be called a "symbol selector". 

[0039] . The interleaves 203. 213, 223, 233 and 243, the MUXes 205 and 215, and the symbol concatenator 207 in 
FIG. 2 correspond to the channel interleaver 102 in FIG. 1. and the symbol sequence repeater 208 and the symbol 
puncturer 209 both correspond to the QCTC generator 103. 

[0040] Returning to FIG. 1 , assuming a mother code rate R=1/5 and 3.072 input information bits, the channel encoder 
101 outputs 15.360 code symbols. Hereinbelow. there will be a description of generating QCTCs with different code 
rates (or data rates), for example, a first QCTC C 0j at 307.2kbps, a second QCTC C^ at 614.4kbps. and a third QCTC 
C^j at 1288.8kbps, from the code symbols. 

[0041] As described before, the 15.360 code symbols are classified into five sub-groups, interleaved, and then re- 
arranged as the symbol sequence of Eq. (8). Then, the 15.360 code symbols are subject to repetition according to a 
predetermined rule and puncturing (or pruning) according to a predetermined sub-code code rate. Thus, an intended 
sub-code is generated. 

[0042] For a data rate of 307.2kbps. if the sub-codes of the first QCTC C 0j are 21 .504 bits in length, the first sub- 
code Cqq is generated by selecting the first 21.504 symbols from the interleaved and repeated symbol sequence. The 
second sub-code C 01 is generated by selecting 21.504 symbols starting with the symbol following the first sub-code 
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from the re P eated symbol sequence. The third sub-code C 02 is generated by selecting-the following 21.504 sym- 
bols. 

[0043] Similarly, for a data rate of 614.4kbps. if the sub-codes of the second QCTC C^are 10.752 bits in length, the 
first sub-code C 10 is generated by selecting the first 10.752 symbols from the repeated symbol sequence. In other 
5 words the first sub-code C 10 is generated by pruning all subsequent symbols following the first 1 0.752 symbols in the 
repeated symbol sequence' The pruning is performed in the symbol puncturer 209 as stated before. The second sub-- 
code C is generated by selecting 10.752 symbols starting with the symbol following the first sub-code C 10 from the 
repeated symbol sequence. The third sub-code C 12 is generated by selecting the 1 0.752 symbols following the second 

sub-code C^- _ 

w [0044] Similarly, for a data rate of 1228.8kbps. if the sub-codes of the third QCTC C 2| are 5.376 bits in length, the 
first sub-code C 20 is generated by selecting the first 5.376 symbols from the repeated symbol sequence. The second 
sub-code C 21 is generated by selecting 5.376 symbols starting with the symbol following the first sub-code C 20 from 
' the repeated symbol sequence. The third sub-code is generated by selecting the following 5.376 symbols. In this 
manner the sub-codes of the QCTC at 1 228.8kbps are generated. 

is [00451 The system stores information about the position of the last symbol in the previous transm.tted sub-code for 
each QCTC When a data rate (or code rate) for retransmission is determined, the system selects a QCTC correspond- 
ing to the data rate and generates a sub-code by selecting a predetermined number of symbols following the stored 
last symbol for the selected QCTC according to the data fate. If the selected symbols exceed one interleaved symbol 
block, the remaining symbols are selected from the following block. In this case, sub-codes are generated by repeating 

20 a block of interleaved symbols. To do so. a storing area is needed to store the repeated blocks. 

[0046] Alternatively, the interleaved symbols can be stored in a circular buffer memory and a sub-code is generated 
by selecting symbols recursively. That is. if interleaved symbols are all selected, a predetermined number of symbols 
are selected from the interleaved symbols starting with the first symbol. Then, the symbol sequence repeater 208 can 
be omitted since the circular buffer memory functions as the symbol sequence repeater 208. 

25 [0047] The above embodiment of the present invention describes two-dimensional QCTCs. In the two-dimensional 
QCTC scheme a QCTC corresponding to each code rate is generated independently and the sub-codes of the QCTC 
are sequentially transmitted. However, the two-dimensional QCTCs are not optimum for the reasons described below. 
[0048] As shown in FIG. 2. it is assumed that the first sub-code C 00 of the first QCTC C oj is used for initial transmission, 
the first sub-code C 10 of the second QCTC C,j is used for the next transmission, and the first sub-code C 20 of the third 

30 QCTC C 2 is used for the third transmission. Then, a receiver decodes data by combining the three sub-codes (C 00 . 
C,n C, 0 ) 'in this case, however, the code combining does not recover an original code with a code rate of 1/5. only to 
increase the symbol energy of information symbols and thus not to optimize decoding performance. This implies that 
there is a problem with the transmission order of the sub-codes, that is. selection of the sub-codes. To overcome the 
problem adaptive QCTCs are propdsed. In the adaptive QCTC scheme, the number of code symbols to be selected 

35 is determined according to the code rate of a sub-code, and the sub-code is generated by select.ng the determined 
number of symbols starting with the symbol following the last symbol used for the previous transmission. 
[0049] FIG 3 is a block diagram of another embodiment of the QCTC generating apparatus. The structure shown 
in FIG 3 is the same as that shown in FIG. 2 except that the symbol sequence repeater and the symbol puncturer. 
operate in different manners. Therefore, the following description is made mainly of the symbol sequence repeater 308 

to and the symbol puncturer 309. . 
[0050] The symbol sequence repeater 308 repeats a symbol sequence received from a symbol concatenator 307 in 
a predetermined way. The repetition may be carried out according to a given parameterin the symbol sequence repeater 
308 or under the control of a higher layer controller (not shown), or upon request of the symbol concatenator 307. The 
above process is implemented in the same manner as described referring to FIG. 2. Then, the symbol puncturer 309 

45 punctures symbols received from the symbol sequence repeater 308 according to a different rule from the rule applied 
in FIG 2 to generate a sub-code. The puncturing rule is as follows. 

[0051] It is assumed that transmission starts at time k. a sub-code transmitted at time (k+h) is expressed as C,(k+h). 

and the code symbols of a mother code with R=1/5 are C m (0). C m (1) C m (N-1). The number of the code symbols. 

N. is defined as LJNFxS since the mother code rate is 1/5. Here. LJNF denotes the size of a sub-block interleaves 
so or the number of information symbols. 

Step 1: the length of an initial sub-code is determined. 

[0052] For an initial transmission, one C i0 of the first sub-codes C 00 . C 10 . C 20 of available QCTCs is selected ac- 
55 cording to a given code rate and the length of the selected sub-code C l0 is stored as a vanable L_SC. The code rate 
or length L_SC of the sub-code is predetermined in the system according to channel environment including transmission 
channel condition and input data rate. The description is made in the context of three QCTCs shown in FIG. 3 for better 
understanding of the present invention, but the number of sub-codes is not limited. 
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Step 2: a sub-code for initial transmission is selected and transmitted. 

[0053] After the length of a sub-code to be transmitted is determined. C m (0), C m (1) C^L^SC-I) are selected 

among the code symbols of the mother code. If L_SC exceeds N, C m (0). C m (1) C m (N) are transmitted P times and 

5 then C m (0). C m (1), .... C m (q-1) are transmitted. Here. P and q are the quotient and remainder of L_SC/N. respectively 
and P and q are calculated by L_SC mod N. Then, the variable q is stored for the next transmission for use in detecting 
the position of the last symbol of the previous transmitted sub-code with respect to the block of interleaved symbols. 

Step 3: the starting position of a sub-code for the next transmission and the length of the sub-code are determined. 

10 

[0054] For the next transmission, the code rate R_SC of a new sub-code to be transmitted is determined according 

to channel environment and the length L_SC of the sub-code is determined according to the determined code rate. v 

The length L_SC and the code rate R_SC is in the relation of 

1b L_SC = LJNF x (VR_SC).... (9) 

A higher layer system transmits the sub-code length l_SC and the sub-code code rate R_SC to the symbol puncturer 
309 for each transmission. 

20 

Step 4: a sub-code for the next transmission is selected and transmitted. 

[0055] After the length L_SC of the sub-code to be transmitted is determined. C m (q). C m (q+1) C m (q+L_SC-1) 

are selected among the code symbols of the mother code. In other words, as many symbols as the sub-code length 

25 are selected from the mother code symbols starting with the symbol following the last symbol selected for the previous 
transmission. If q+L_SC exceeds N, a row comprised of N code symbols starting with C m (q) are selected recursively 
and transmitted P times and then the remaining q' code symbols are sequentially transmitted. Here. P and q' are the 
quotient and remainder of (L_SC)/N, respectively and the q* is calculated by (q+L_SC) mod N. Then, the next symbol 
position value of the position of the last selected symbol for the next transmission is stored to the q. The variable q is 

30 the next symbol position of the last symbol position among symbols comprised of the last transmitted sub-code. After 
the generated sub-code is transmitted, the procedure returns to step 3. 

[0056] The transmission of adaptive QCTCs will be made clear with cases shown in FIG. 3. Referring to FIG. 3. a 
low rate sub-code with a code rate of 1/7 is initially transmitted in Case 1. and a high rate sub-code with a code rate 
of 4/7 is initially transmitted in Case 2. "As seen from the cases. N (=15.360) successive mother code symbols are 

35 repeated and as many code symbols as a size corresponding to the length of a sub-code to be transmitted (or the 
code rate of the sub-code) are selected sequentially from the repeated mother code symbols, at each transmission. 
[0057] In real implementation, a buffer is not used to store (P-1 ) times repeated-mother codes, but a single circular 
buffer is employed to store N code symbols and recursively select code symbols to thereby generate a sub-code of 
an intended length. That is. use of the circular buffer memory obviates the need of sequence repetition. Any reception 

40 buffer is available to a receiver as long as it can store N soft metrics for code combining. 

[0058] While the invention has been shown and described with reference to certain preferred embodiments thereof, 
it will be understood by those skilled in the art that various changes in form and details may be made therein without 
departing from the spirit and scope of the invention as defined by the appended claims. 

45 

Claims 

1. A QCTC (Quasi-Complementary Turbo Code) generating apparatus comprising: 

so a turbo encoder having a plurality of constituent encoders, for generating an information symbol sequence 

and a plurality of parity symbol sequences according to a given code rate. by encoding the information symbol 
sequence. . each of the constituent encoders for generating at least one parity symbol sequence, the at least 
one parity symbol sequence from one constituent encoder corresponding to the at least one parity symbol 
sequence from another constituent encoder; 

55 a channel interleaver for individually interleaving the information symbol sequence and the parity symbol se- 

quences, alternately arranging the symbols of the corresponding parity symbol sequences, and serially con- 
catenating the interleaved information symbol sequence and the arranged parity symbol sequences; and 
a QCTC generator for generating a sub-code of a QCTC by repeating the serially concatenated symbol se- 
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quence and selecting a predetermined number of symbols from the repeated symbol sequence according to 
code rate and selection information. 

The QCTC generating apparatus of claim 1. wherein the channel interleaver comprises: 

a plurality of interleaves for individually interleaving the information symbol sequence and the plurality of parity 
rmul^eXToTgenerating a new parity symbol sequence by multiplexing the interleaved symbols of the 
• T^^^^^Z^^n, the interleaved information symbol sequence and the new 

parity symbol sequence. 
The QCTC generating apparatus of claim 1 . wherein the QCTC generator comprises: 
a svmbol repeater for repeating the serially concatenated symbol sequence: and 

1 symbol selector for generating the sub-code by selecting a predetermined number of symbols from the 
repeated symbol sequence at a given starting position according to a given code rate. 

4. The QCTC generating apparatus of claim 3. wherein the given starting position is the position of a symbol following 
20 the last symbol selected for the previous transmission. 

5. The QCTC generating apparatus of claim 1 . wherein the QCTC generator comprises: 
a circular buffer memory for storing the serially concatenated symbol sequence: and 

a symbol selector for generating the sub-code by selecting a predetermined number of symbols from the 
serially concatenated symbol sequence at a given starting position according to a g.ven code rate. 

6. The QCTC generating apparatus of claim 5. wherein the given starting position is the position of a symbol following 
the last symbol selected for the previous transmission. 

7 The QCTC Generating apparatus of claim 1 . wherein the QCTC generator generates the sub-code by selecting a 
-JEWESS S oTsymbols from the repeated symbol sequence according to a given code rate, startmg 
with a symbol following the last symbol selected for the previous transm.ss.on. 

8 The QCTC Generating apparatus of claim 1 . wherein the channel interleaver individually interleaves the information 
lymbo^Iequence fanS ^plurality of parity symbol sequences by PBRO (Partial Bit Reversal Order) .nterleav.ng. 

9. A QCTC (Quasi-Complementary Turbo Code) generating apparatus comprising: 

a turbo encoder having a plurality of constituent encoders, for generating an informati °; 
and a plurality of parity symbol sequences by encoding the informat.cn symbol sequence, each consent 
encoder for generating at least one parity symbol sequence corresponding to at .east one parity symbol se- 
auence from another constituent encoder; -^..^-a.. 
anlnterleaver for individually interleaving the information symbol sequence and the panty symb oh ^uw« 
a multiplexer for generating a new parity symbol sequence by multiplexing the mterleaved symbols of the 

T^^^^^Z^ g the interleaved information symbol sequence and the new 

TQ^T^ZZVnL, g a sub-code of a QCTC with a given code rate by recursively selecting a 
IreSleZZnlberll symbols from the serially concatenated symboi sequence at a given startmg pos.t.on 
according to the code rate. 

1 0 The QCTC generating apparatus of claim 9. wherein the interleaver individually interleaves the information symbol 
lequenc, Tand the p.uraNty of parity symbol sequences by PBRO (Partial Bit Reversal Order) .nterleav.ng. 

1 1 . The QCTC generating apparatus of claim 9. wherein the given starting position is the position of a symbol following 
the last symbol selected for the previous transmission. 
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12. The QCTC generating apparatus of daim 9. wherein the QCTC generator comprises: 

a symbol repeater for repeating the serially concatenated symbol sequence; and 

a symbol selector for generating the sub-code by selecting the predetermined number of symbols from the 
5 repeated symbol sequence according to the given code rate. 

13. The QCTC generating apparatus of claim 9, wherein the QCTC generator comprises: 

a circular buffer memory for storing the serially concatenated symbol sequence; and 
w a symbol selector for generating the sub-code by selecting the predetermined number of symbols from the 

serially concatenated symbol sequence at the given starting position according to the given code rate. 

14. A QCTC (Quasi-Complementary Turbo Code) generating apparatus comprising: 

15 a turbo encoder for generating an information symbol sequence and a plurality of parity symbol sequences 

by encoding the information symbol sequence; 

a channel interleaver for individually interleaving the information symbol sequence and the parity symbol se- 
quences, generating new parity symbol sequences by multiplexing the symbols of parity symbol sequences 
with the same priority levels, and serially concatenating the information symbol sequence and the new parity 
20 symbol sequences; and 

a QCTC generator for generating a sub-code of a QCTC with a given code rate by recursively selecting a 
predetermined number of symbols from the serially concatenated symbol sequence at a given starting position 
according to the code rate. 

25 15. The QCTC generating apparatus of claim 14, wherein the turbo encoder comprises a plurality of constituent en- 
coders, each constituent encoder generating at least one parity symbol sequence, and at least one interleaver. 
wherein a primary parity symbol sequence from each constituent encoder has a higher priority level. 

16. The QCTC generating apparatus of claim 14, wherein the given starting position is the position of a symbol following 
30 the last symbol selected for the previous transmission. 

17. A QCTC (Quasi-Complementary Turbo Code) generating method comprising the steps of: 

generating an information symbol sequence and a plurality of parity symboJ sequences by encoding the infor- 
ms mation symbol sequence, the plurality of parity symbol sequences being generated from constituent encoders, 
at least one parity symbol sequence being generated from each of the constituent encoders, and the at least 
one parity symbol sequence from one constituent encoder corresponding to the at least one parity symbol 
sequence from another constituent encoder: 

individually interleaving the information symbol sequence and the parity symbol sequences; 
40 generating a new parity symbol sequence by multiplexing the interleaved symbols of the corresponding parity 

symbol sequences; 

serially concatenating the interleaved information symbol sequence and the new parity symbol sequence; and 
generating a sub-code of a QCTC with a given code rate by recursively selecting a predetermined number of 
symbols from the serially concatenated symbol sequence at a given starting position according to the code rate. 

45 

18. The QCTC generating method of claim 1 7. wherein the interleaving step is performed by PBRO (Partial Bit Reversal 
Order) interleaving. 

19. The QCTC generating method of claim 1 7. wherein the given starting position is the position of a symbol following 
so the fast symbol selected for the previous transmission. 

20: The QCTC generating method of claim 17. wherein the QCTC generation step comprises the steps of: 

repeating the serially concatenated symbol sequence; and 
55 generating the sub-code by selecting the predetermined number of symbols from the repeated symbol se- 

quence according to the given code rate. 

21. The QCTC generating method of claim 17. wherein the QCTC generation step comprises the steps of: 
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storing the serially concatenated symbol sequence in a circular buffer memory: and 

generating the sub-code by selecting the predetermined number of symbols from the circular buffer memory 
at the given starting position according to the given code rate. 
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storing the serially concatenated symbol sequence in a circular buffer memory; and 

generating the sub-code by selecting the predetermined number of symbols from the circular buffer memory 
at the given starting position according to the given code rate. 
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